Continuous Integration (CI) এবং JasmineJS

Web Development - জ্যাসমিনজেএস (JasmineJS)
403

Continuous Integration (CI) একটি সফটওয়্যার ডেভেলপমেন্ট প্র্যাকটিস, যেখানে ডেভেলপাররা নিয়মিতভাবে কোড পরিবর্তন রিপোজিটরিতে যোগ করেন এবং সেই কোডের জন্য অটোমেটিক টেস্ট চালানো হয়। CI এর মূল লক্ষ্য হল কোড ইন্টিগ্রেশন এবং টেস্টিং প্রক্রিয়াকে স্বয়ংক্রিয় করা, যাতে কোডের মান এবং সঠিকতা নিশ্চিত করা যায়। JasmineJS একটি জনপ্রিয় JavaScript টেস্টিং ফ্রেমওয়ার্ক, যা CI প্রক্রিয়ার অংশ হিসেবে খুবই কার্যকরী।

CI ব্যবস্থায় JasmineJS এর মাধ্যমে টেস্ট অটোমেশন করতে পারবেন, যার ফলে সফটওয়্যার ডেভেলপমেন্টের সময় দ্রুত এবং নির্ভরযোগ্য কোড ডেলিভারি নিশ্চিত হবে। এখানে, আমরা দেখবো কীভাবে JasmineJS কে CI প্ল্যাটফর্মের সঙ্গে ইন্টিগ্রেট করা যায় এবং কীভাবে JasmineJS CI প্রক্রিয়ায় সাহায্য করে।


JasmineJS এবং Continuous Integration

JasmineJS টেস্টিং ফ্রেমওয়ার্ককে Continuous Integration (CI) প্ল্যাটফর্মের সাথে ইন্টিগ্রেট করে স্বয়ংক্রিয়ভাবে কোড টেস্ট করা সম্ভব। CI প্ল্যাটফর্মের সাহায্যে টেস্টগুলো নিয়মিতভাবে রান করা যায়, যার ফলে নতুন কোড যুক্ত করার পর সিস্টেমের মধ্যে কোনো সমস্যা থাকলে তা সহজেই চিহ্নিত করা যায়। এর মাধ্যমে কোডের গুণমান এবং নির্ভরযোগ্যতা বাড়ানো যায়।

CI এর মধ্যে JasmineJS কে ইন্টিগ্রেট করার কয়েকটি গুরুত্বপূর্ণ ধাপ নিচে আলোচনা করা হলো।


CI প্ল্যাটফর্ম এবং JasmineJS এর ইন্টিগ্রেশন

CI প্ল্যাটফর্মের মধ্যে কিছু জনপ্রিয় সেবা রয়েছে যেমন Travis CI, CircleCI, GitHub Actions এবং Jenkins। এই প্ল্যাটফর্মগুলোতে JasmineJS এর টেস্ট রান করার জন্য সাধারণত npm স্ক্রিপ্টের মাধ্যমে JasmineJS কনফিগার করতে হয়।

1. Travis CI এবং JasmineJS ইন্টিগ্রেশন

Travis CI একটি জনপ্রিয় CI সেবা যা GitHub রিপোজিটরির সাথে সরাসরি ইন্টিগ্রেট করা যায়। JasmineJS টেস্টিং ফ্রেমওয়ার্ককে Travis CI এর মাধ্যমে টেস্ট রান করার জন্য এই পদক্ষেপগুলি অনুসরণ করতে হবে:

  1. Travis CI কনফিগারেশন ফাইল তৈরি:

    প্রথমে একটি .travis.yml ফাইল তৈরি করতে হবে, যাতে ট্রাভিসকে জানানো হবে কিভাবে JasmineJS টেস্ট রান করতে হবে।

    language: node_js
    node_js:
      - "14"
    
    install:
      - npm install
    
    script:
      - npm test  # এখানে JasmineJS টেস্ট রান করা হবে
    
  2. GitHub রিপোজিটরির সাথে Travis CI ইন্টিগ্রেট করা:

    GitHub রিপোজিটরিতে Travis CI ইন্টিগ্রেট করার পর, আপনি npm test চালানোর মাধ্যমে JasmineJS টেস্টগুলি চালাতে পারবেন। Travis CI স্বয়ংক্রিয়ভাবে কোড পুশ হলে টেস্টগুলো রান করবে।

  3. Test Results:

    Travis CI এর UI তে আপনি টেস্ট রেজাল্ট দেখতে পারবেন। যদি কোনো টেস্ট ব্যর্থ হয়, আপনি বিস্তারিত লগ চেক করে সমস্যার সমাধান করতে পারবেন।

2. CircleCI এবং JasmineJS ইন্টিগ্রেশন

CircleCI আরেকটি জনপ্রিয় CI সেবা যা JasmineJS টেস্টের জন্য ব্যবহার করা যেতে পারে। CircleCI তে JasmineJS টেস্টিং সেটআপ করার জন্য config.yml ফাইল তৈরি করতে হয়।

  1. CircleCI কনফিগারেশন ফাইল তৈরি:

    .circleci/config.yml ফাইল তৈরি করুন:

    version: 2.1
    
    jobs:
      test:
        docker:
          - image: circleci/node:14
        steps:
          - checkout
          - run:
              name: Install dependencies
              command: npm install
          - run:
              name: Run Jasmine Tests
              command: npm test
    
    workflows:
      version: 2
      test:
        jobs:
          - test
    
  2. CircleCI সেটআপ:

    CircleCI তে একটি প্রজেক্ট তৈরি করে এই কনফিগারেশন ফাইলটি রিপোজিটরিতে যুক্ত করুন। CircleCI এর মাধ্যমে JasmineJS টেস্ট স্বয়ংক্রিয়ভাবে রান হবে এবং টেস্ট ফলাফল CircleCI এর UI তে দেখা যাবে।

3. GitHub Actions এবং JasmineJS ইন্টিগ্রেশন

GitHub Actions একটি শক্তিশালী CI/CD টুল যা GitHub রিপোজিটরির মধ্যে ইন্টিগ্রেট করা হয়। JasmineJS টেস্টের জন্য একটি GitHub Actions workflow তৈরি করতে পারেন।

  1. GitHub Actions কনফিগারেশন ফাইল তৈরি:

    .github/workflows/test.yml ফাইল তৈরি করুন:

    name: Run Jasmine Tests
    
    on: [push]
    
    jobs:
      test:
        runs-on: ubuntu-latest
        steps:
          - uses: actions/checkout@v2
          - name: Set up Node.js
            uses: actions/setup-node@v2
            with:
              node-version: '14'
          - run: npm install
          - run: npm test
    
  2. GitHub Actions ব্যবহার:

    প্রতিবার যখন কোড রিপোজিটরিতে পুশ হবে, GitHub Actions স্বয়ংক্রিয়ভাবে JasmineJS টেস্ট রান করবে এবং টেস্ট ফলাফল Actions UI তে দেখাবে।


CI এ JasmineJS এর সুবিধা

  1. স্বয়ংক্রিয় টেস্টিং: JasmineJS এর টেস্ট গুলি CI সিস্টেমের মাধ্যমে স্বয়ংক্রিয়ভাবে রান হয়, ফলে কোড পরিবর্তন করার সাথে সাথে টেস্ট করা সম্ভব হয়।
  2. বাগ এবং সমস্যার দ্রুত চিহ্নিতকরণ: CI প্ল্যাটফর্মে JasmineJS টেস্ট চলার মাধ্যমে যে কোনো কোড পরিবর্তনের পর সমস্যা দ্রুত সনাক্ত করা যায়।
  3. টেস্টের বিশ্বস্ততা: কোডের প্রতিটি অংশের জন্য টেস্ট রান করা হয়, যা কোডের গুণমান এবং বিশ্বস্ততা নিশ্চিত করে।
  4. ডেভেলপমেন্টের গতি বৃদ্ধি: নিয়মিত টেস্টিংয়ের মাধ্যমে কোনো বাগ বা সমস্যা দ্রুত ধরা পড়ে, ফলে ডেভেলপমেন্টের গতি বৃদ্ধি পায়।

সারাংশ

Continuous Integration (CI) প্রক্রিয়ায় JasmineJS ব্যবহার করে স্বয়ংক্রিয়ভাবে টেস্টিং চালানো সম্ভব। JasmineJS CI প্ল্যাটফর্মে ইন্টিগ্রেট হলে, কোডের প্রতিটি পরিবর্তনের পর স্বয়ংক্রিয়ভাবে টেস্ট রানের মাধ্যমে কোডের সঠিকতা এবং গুণমান নিশ্চিত করা যায়। Travis CI, CircleCI, এবং GitHub Actions এর মতো প্ল্যাটফর্মে JasmineJS ইন্টিগ্রেট করে এই টেস্টিং প্রক্রিয়াকে আরও কার্যকর এবং নির্ভরযোগ্য করা যায়। JasmineJS CI প্রক্রিয়ায় খুবই কার্যকরী, যা কোড ডেলিভারি এবং টেস্টিংয়ের জন্য উন্নত সমাধান প্রদান করে।

Content added By

Continuous Integration (CI) এর ধারণা

263

Continuous Integration (CI) একটি সফটওয়্যার ডেভেলপমেন্ট প্র্যাকটিস যেখানে কোড পরিবর্তনগুলিকে একটি কেন্দ্রীয় রিপোজিটরিতে নিয়মিত (দিনে একাধিকবার) ইন্টিগ্রেট (মিলানো) করা হয়। এর মাধ্যমে সফটওয়্যার ডেভেলপমেন্টের বিভিন্ন অংশ একত্রিত করে অটোমেটিক্যালি টেস্ট এবং বিল্ড করা হয়। CI পদ্ধতি ব্যবহার করে, ডেভেলপাররা তাদের কোড পরিবর্তনগুলো দ্রুত এবং সঠিকভাবে যাচাই করতে পারে এবং পুরো সিস্টেমে ইন্টিগ্রেশন নিয়ে কোনো সমস্যা থাকলে দ্রুত শনাক্ত করতে পারে।

JasmineJS এর মতো টেস্টিং ফ্রেমওয়ার্ক CI প্রক্রিয়াতে গুরুত্বপূর্ণ ভূমিকা পালন করে, কারণ এটি কোডের প্রতিটি অংশের কাজ সঠিকভাবে হচ্ছে কিনা তা যাচাই করতে সাহায্য করে।


Continuous Integration (CI) এর প্রক্রিয়া

CI প্রক্রিয়া কিছু সাধারণ স্টেপ অনুসরণ করে:

  1. কোড রিপোজিটরিতে আপলোড: ডেভেলপাররা কোড রিপোজিটরিতে তাদের পরিবর্তন আপলোড করে। সাধারণত GitHub, GitLab বা Bitbucket এর মতো ভার্সন কন্ট্রোল সিস্টেম ব্যবহার করা হয়।
  2. CI টুল ট্রিগার: কোড আপলোড হওয়ার সাথে সাথে CI টুল (যেমন Jenkins, Travis CI, CircleCI) স্বয়ংক্রিয়ভাবে চালু হয়ে কাজ শুরু করে। এটি রিপোজিটরিতে নতুন কোড চেক আউট করে এবং টেস্ট রান করতে শুরু করে।
  3. টেস্ট রান: JasmineJS বা অন্যান্য টেস্টিং ফ্রেমওয়ার্ক ব্যবহার করে কোডের সঠিকতা যাচাই করা হয়। এই টেস্টিং প্রক্রিয়ায় বিভিন্ন ইউনিট টেস্ট, ইন্টিগ্রেশন টেস্ট এবং সিস্টেম টেস্ট সম্পন্ন করা হয়।
  4. ফলাফল রিপোর্ট করা: টেস্টের ফলাফল স্বয়ংক্রিয়ভাবে CI সিস্টেম দ্বারা জেনারেট করা হয় এবং ডেভেলপারকে জানানো হয় যদি কোনো টেস্ট ফেইল হয়। ফলাফলগুলি সাধারণত ইমেইল বা স্ল্যাক চ্যানেলের মাধ্যমে পাওয়া যায়।
  5. বিল্ড এবং ডিপ্লয়মেন্ট: যদি সব টেস্ট সফলভাবে পাস হয়, তখন কোড বিল্ড এবং ডিপ্লয়মেন্ট প্রক্রিয়া স্বয়ংক্রিয়ভাবে সম্পন্ন হয়। এই প্রক্রিয়াটি স্টেজিং বা প্রোডাকশন পরিবেশে কোড ডিপ্লয় করে।

JasmineJS এবং CI প্রক্রিয়ার ইন্টিগ্রেশন

JasmineJS কে CI প্রক্রিয়ায় ইন্টিগ্রেট করতে, সাধারণত কিছু টুল এবং প্ল্যাটফর্ম ব্যবহার করা হয় যা Jasmine এর টেস্ট রান এবং ফলাফল স্বয়ংক্রিয়ভাবে পরিচালনা করতে সাহায্য করে।


CI প্রক্রিয়ায় JasmineJS ব্যবহার করার জন্য কিছু টুল

  1. Jenkins: Jenkins একটি জনপ্রিয় অটোমেশন টুল যা CI/CD (Continuous Integration/Continuous Deployment) প্রসেসের জন্য ব্যবহৃত হয়। JasmineJS এর টেস্টগুলিকে Jenkins এর মাধ্যমে চালানো যায়, এবং এটি সফলভাবে কোডের বিল্ড, টেস্টিং এবং ডিপ্লয়মেন্ট প্রক্রিয়া অটোমেট করতে সাহায্য করে।
  2. Travis CI: Travis CI একটি ক্লাউড-ভিত্তিক CI টুল যা GitHub রিপোজিটরির সাথে ইন্টিগ্রেট হয়। JasmineJS টেস্ট রান করার জন্য Travis CI খুবই উপকারী, যেখানে আপনাকে কেবল .travis.yml ফাইল কনফিগার করতে হয়।
  3. CircleCI: CircleCI একটি পোর্টেবল এবং দ্রুত CI/CD টুল। JasmineJS টেস্টিং এর জন্য CircleCI ব্যবহার করতে পারেন, যেখানে স্বয়ংক্রিয়ভাবে টেস্ট, বিল্ড এবং ডিপ্লয়মেন্ট করা হয়।

JasmineJS টেস্টকে CI এ ব্যবহার করার উদাহরণ

ধরা যাক, আপনি Travis CI ব্যবহার করছেন এবং আপনার প্রোজেক্টে JasmineJS দিয়ে টেস্ট লিখেছেন। আপনি Travis CI সেটআপ করবেন যাতে কোড আপলোড হলে টেস্ট অটোমেটিক্যালি চালানো হয়।

1. Travis CI সেটআপ

প্রথমে, আপনার রিপোজিটরিতে একটি .travis.yml ফাইল যোগ করতে হবে। এই ফাইলটি Travis CI কে নির্দেশনা দেবে কিভাবে টেস্ট রান করতে হবে।

language: node_js
node_js:
  - "14"
before_script:
  - npm install jasmine
script:
  - jasmine

এই কনফিগারেশনে:

  • language: node_js: এটি Travis CI কে বলে যে, আপনার প্রোজেক্ট Node.js ভিত্তিক।
  • node_js: "14": এটি Travis CI কে নির্দেশ দিচ্ছে যে, Node.js সংস্করণ 14 ব্যবহার করতে হবে।
  • before_script: এখানে Jasmine টেস্ট ফ্রেমওয়ার্ক ইনস্টল করা হচ্ছে।
  • script: এখানে Jasmine টেস্ট রান করার জন্য jasmine কমান্ড ব্যবহার করা হচ্ছে।

2. GitHub রিপোজিটরিতে কোড আপলোড করা

একবার আপনি .travis.yml ফাইলটি রিপোজিটরিতে যোগ করেছেন, এরপর আপনার কোডে কোনো পরিবর্তন বা নতুন ফিচার যোগ করলে সেটা রিপোজিটরিতে পুশ (push) করুন।

3. টেস্ট ফলাফল

Travis CI রিপোজিটরি থেকে কোড ক্লোন করে, JasmineJS টেস্টগুলো চালাবে এবং আপনি টেস্ট ফলাফল দেখতে পারবেন। যদি কোনো টেস্ট ব্যর্থ হয়, Travis CI তা স্বয়ংক্রিয়ভাবে রিপোর্ট করবে।


CI প্রক্রিয়াতে JasmineJS এর সুবিধা

  1. অটোমেটেড টেস্টিং: CI প্রক্রিয়ায় JasmineJS টেস্ট স্বয়ংক্রিয়ভাবে চালানো হয়, ফলে কোডের প্রতি পরিবর্তন বা আপডেটের পর যেকোনো সময় কোডের সঠিকতা পরীক্ষা করা যায়।
  2. নির্ভরযোগ্য বিল্ড: CI সিস্টেমের মাধ্যমে আপনি নিশ্চিত হতে পারেন যে কোডের যে কোনো অংশ যেকোনো সময়ে সঠিকভাবে কাজ করছে এবং কোনো সমস্যা না হলে বিল্ড সফল হবে।
  3. দ্রুত ফিডব্যাক: JasmineJS টেস্ট সিস্টেম CI সিস্টেমে ইন্টিগ্রেট করা হলে দ্রুত ফিডব্যাক পাওয়া যায়, যাতে ডেভেলপাররা দ্রুত সমস্যাগুলি সমাধান করতে পারেন।
  4. কোডের গুণগত মান নিশ্চিত করা: CI প্রক্রিয়ায় JasmineJS টেস্ট সঠিকভাবে চালানোর মাধ্যমে কোডের গুণগত মান বজায় রাখা সহজ হয়।

সারাংশ

  • Continuous Integration (CI) প্রক্রিয়ায় কোড নিয়মিতভাবে রিপোজিটরিতে ইন্টিগ্রেট করা হয় এবং অটোমেটিকভাবে টেস্ট ও বিল্ড করা হয়।
  • JasmineJS CI এর মাধ্যমে স্বয়ংক্রিয়ভাবে কোডের টেস্ট করতে সহায়তা করে, যা উন্নত কোড গুণমান এবং দ্রুত ফলাফল প্রদান করে।
  • CI টুলস যেমন Jenkins, Travis CI, এবং CircleCI এর সাহায্যে JasmineJS টেস্ট সহজেই ইন্টিগ্রেট করা যায়।
  • CI প্রক্রিয়ায় JasmineJS ব্যবহারে ডেভেলপাররা দ্রুত এবং নির্ভরযোগ্য ফিডব্যাক পেয়ে, সঠিক কোড ডেলিভারি নিশ্চিত করতে পারেন।
Content added By

CI পরিবেশে স্বয়ংক্রিয় টেস্ট রান করা

284

Continuous Integration (CI) হল একটি উন্নত সফটওয়্যার ডেভেলপমেন্ট প্র্যাকটিস যেখানে কোড পরিবর্তনগুলি বারবার অটোমেটিক্যালি একটি শেয়ারড রিপোজিটরিতে মেশানো হয়। CI পরিবেশে টেস্টিং স্বয়ংক্রিয়ভাবে চালানোর মাধ্যমে, উন্নত সফটওয়্যার মান এবং দ্রুত সমস্যা শনাক্তকরণ সম্ভব হয়। JasmineJS ব্যবহার করে CI সিস্টেমে স্বয়ংক্রিয় টেস্ট রান করা সহজ এবং কার্যকরী।

এই গাইডে, আমরা দেখব কিভাবে JasmineJS ব্যবহার করে CI পরিবেশে স্বয়ংক্রিয়ভাবে টেস্ট চালানো যেতে পারে, এবং এটি কীভাবে বিভিন্ন CI সার্ভিসে কার্যকরভাবে সেটআপ করা হয়।


JasmineJS এবং Karma দিয়ে CI পরিবেশে টেস্ট রান করা

Karma হল একটি টেস্ট রানার যা JasmineJS এর সাথে যুক্ত হয়ে ব্রাউজারে টেস্ট চালাতে সহায়তা করে। এটি CI পরিবেশে টেস্টিং স্বয়ংক্রিয় করতে সাহায্য করে। আপনাকে প্রথমে Karma এবং অন্যান্য প্রয়োজনীয় প্যাকেজ ইনস্টল করতে হবে, তারপর CI সার্ভিস যেমন Travis CI, Jenkins বা GitLab CI এ টেস্ট রানের জন্য কনফিগারেশন করতে হবে।

1. Karma সেটআপ করা

প্রথমে আপনার প্রজেক্টে Karma এবং JasmineJS প্যাকেজ ইনস্টল করতে হবে:

npm install karma karma-jasmine karma-chrome-launcher jasmine-core --save-dev

এখানে:

  • karma-jasmine: Jasmine এর জন্য Karma অ্যাডাপ্টার।
  • karma-chrome-launcher: Chrome ব্রাউজারে টেস্ট চালানোর জন্য।

2. Karma কনফিগারেশন ফাইল তৈরি করা

Karma কনফিগারেশন ফাইল (karma.conf.js) তৈরি করুন, যা টেস্ট চালানোর জন্য প্রয়োজনীয় সেটিংস ধারণ করবে।

karma init karma.conf.js

এরপর karma.conf.js ফাইলটি এভাবে কনফিগার করুন:

module.exports = function(config) {
  config.set({
    frameworks: ['jasmine'], // Jasmine ফ্রেমওয়ার্ক ব্যবহার
    files: [
      'src/**/*.js',  // আপনার সোর্স কোড ফাইল
      'test/**/*.spec.js' // টেস্ট কেস ফাইল
    ],
    browsers: ['Chrome'], // টেস্ট চালানোর জন্য ব্রাউজার
    reporters: ['progress'], // রিপোর্টিং স্টাইল
    singleRun: true // একবার টেস্ট রান হবে
  });
};

এখানে:

  • files: টেস্ট চালানোর জন্য যেসব ফাইল প্রয়োজন, সেগুলো উল্লেখ করতে হবে।
  • browsers: যেসব ব্রাউজারে টেস্ট চালানো হবে, সেই ব্রাউজার উল্লেখ করতে হবে।
  • singleRun: এটি CI পরিবেশে একটি একক রান হবে।

3. Karma দিয়ে টেস্ট রান করা

Karma কনফিগারেশন ফাইল তৈরি করার পর, টেস্ট চালানোর জন্য নিম্নলিখিত কমান্ডটি ব্যবহার করতে হবে:

karma start karma.conf.js

এটি টেস্টগুলো চালাবে এবং ফলাফল দেখাবে। CI পরিবেশে এই প্রক্রিয়াটি স্বয়ংক্রিয়ভাবে রান করবে।


CI সার্ভিসে JasmineJS টেস্ট রান করা

CI সিস্টেমের মাধ্যমে JasmineJS টেস্ট স্বয়ংক্রিয়ভাবে রান করতে হলে, আপনি টেস্টিং সিস্টেমে সংশ্লিষ্ট কনফিগারেশন যুক্ত করতে হবে। নীচে আমরা দুটি জনপ্রিয় CI সিস্টেম Travis CI এবং Jenkins এর মাধ্যমে JasmineJS টেস্ট রান করার প্রক্রিয়া দেখব।

1. Travis CI এ JasmineJS টেস্ট রান করা

Travis CI হল একটি জনপ্রিয় CI সিস্টেম যা গিটহাব রিপোজিটরির সাথে ইন্টিগ্রেট করা যায়। Travis CI সিস্টেমে JasmineJS টেস্ট চালাতে:

  1. প্রথমে আপনার গিটহাব রিপোজিটরিতে .travis.yml ফাইলটি তৈরি করুন:
language: node_js
node_js:
  - "14"  # আপনার প্রয়োজনীয় Node.js ভার্সন উল্লেখ করুন
install:
  - npm install
script:
  - karma start karma.conf.js --singleRun

এখানে:

  • language: node_js: Travis CI কে বলে দেয় যে Node.js ব্যবহার হবে।
  • install: প্রয়োজনীয় প্যাকেজ ইনস্টল করা হবে।
  • script: এখানে Karma কমান্ড ব্যবহার করা হয়েছে যা JasmineJS টেস্ট চালাবে।
  1. এরপর Travis CI আপনার রিপোজিটরি থেকে কোড পুল করে, টেস্ট চালাবে এবং ফলাফল দেখাবে।

2. Jenkins এ JasmineJS টেস্ট রান করা

Jenkins সিস্টেমে JasmineJS টেস্ট চালাতে নিম্নলিখিত পদক্ষেপগুলো অনুসরণ করতে হবে:

  1. Jenkins সার্ভারে একটি নতুন জব তৈরি করুন।
  2. Source Code Management এ আপনার গিট রিপোজিটরি URL দিন।
  3. Build Steps এ একটি Shell Script রান করুন:
npm install
karma start karma.conf.js --singleRun

এটি Karma কমান্ডের মাধ্যমে JasmineJS টেস্ট চালাবে।

  1. Jenkins স্বয়ংক্রিয়ভাবে টেস্ট চালানোর পর রিপোর্ট দেখাবে।

PhantomJS দিয়ে হেডলেস ব্রাউজার টেস্টিং

JasmineJS টেস্ট CI সিস্টেমে চালানোর সময় আপনি PhantomJS ব্যবহার করে হেডলেস ব্রাউজার টেস্টও করতে পারেন। PhantomJS একটি হেডলেস ব্রাউজার যা UI রেন্ডারিং ছাড়া কোড টেস্ট করতে সহায়তা করে।

Karma কনফিগারেশনে PhantomJS ব্যবহার করার জন্য:

browsers: ['PhantomJS']

এটি Karma টেস্ট রানারকে PhantomJS ব্রাউজারে টেস্ট চালানোর নির্দেশ দিবে।


সারাংশ

JasmineJS এবং Karma ব্যবহার করে আপনি CI (Continuous Integration) পরিবেশে টেস্ট স্বয়ংক্রিয়ভাবে চালাতে পারেন। Karma টেস্ট রানার JasmineJS এর সাথে ইন্টিগ্রেট করে বিভিন্ন ব্রাউজারে টেস্ট চালাতে সহায়তা করে, এবং CI সার্ভিস যেমন Travis CI বা Jenkins এ কোড পুশ করলে টেস্টগুলি স্বয়ংক্রিয়ভাবে রান হবে। PhantomJS ব্যবহার করে হেডলেস ব্রাউজারে টেস্ট চালানো সম্ভব, যা CI সিস্টেমে আরও দ্রুত এবং লাইটওয়েট টেস্টিং নিশ্চিত করে।

Content added By

CI/CD Pipeline এর সাথে JasmineJS Integration

211

CI/CD (Continuous Integration/Continuous Deployment) একটি সফটওয়্যার ডেভেলপমেন্ট প্রক্রিয়া যেখানে কোডে পরিবর্তন আসার পর তা অটোমেটিকভাবে বিল্ড, টেস্ট এবং ডিপ্লয় করা হয়। JasmineJS টেস্টিং ফ্রেমওয়ার্কের সাথে CI/CD ইন্টিগ্রেশন করে আপনি নিশ্চিত করতে পারেন যে, প্রতিটি কোড আপডেটের পরে স্বয়ংক্রিয়ভাবে টেস্ট চালানো হচ্ছে এবং সঠিক ফলাফল পাওয়া যাচ্ছে।

CI/CD এর মাধ্যমে টেস্টগুলো ধারাবাহিকভাবে চলতে থাকে এবং এটি ত্রুটি খুঁজে বের করতে সহায়তা করে, যা ডেভেলপমেন্ট প্রক্রিয়াকে আরও নিরাপদ এবং দ্রুত করে তোলে।


CI/CD Pipeline কি?

Continuous Integration (CI): একাধিক ডেভেলপার যখন একসাথে একটি কোডবেসে কাজ করে, তখন প্রতিটি কোড আপডেটের পরে স্বয়ংক্রিয়ভাবে বিল্ড এবং টেস্ট চালানো হয়।

Continuous Deployment (CD): টেস্ট সফল হলে কোড স্বয়ংক্রিয়ভাবে প্রোডাকশনে ডিপ্লয় করা হয়।

CI/CD পদ্ধতির মাধ্যমে কোডের গুণগত মান এবং স্থায়িত্ব নিশ্চিত করা সম্ভব হয়। JasmineJS এর সাথে CI/CD ইন্টিগ্রেশন করলে, আপনি কোডে পরিবর্তন করার সাথে সাথে আপনার টেস্টগুলো চালাতে পারবেন এবং নিশ্চিত হতে পারবেন যে নতুন কোডটি পূর্ববর্তী ফিচারের সাথে সামঞ্জস্যপূর্ণ এবং কোনো নতুন ত্রুটি সৃষ্টি করছে না।


JasmineJS এবং CI/CD টুলস ইন্টিগ্রেশন

JasmineJS এর সাথে CI/CD টুলস যেমন Jenkins, GitLab CI, Travis CI, CircleCI, GitHub Actions ব্যবহার করে আপনি স্বয়ংক্রিয়ভাবে টেস্ট রান করতে পারেন। নিচে কিছু জনপ্রিয় CI/CD টুলের সাথে JasmineJS ইন্টিগ্রেশনের বিস্তারিত আলোচনা করা হলো।


Jenkins এর সাথে JasmineJS Integration

Jenkins একটি জনপ্রিয় CI/CD টুল যা আপনাকে আপনার কোডের বিল্ড এবং টেস্টিং প্রক্রিয়া অটোমেট করতে সাহায্য করে।

Steps to Integrate JasmineJS with Jenkins:

  1. Jenkins ইনস্টল করা: Jenkins আপনার সিস্টেমে ইনস্টল করতে হবে। আপনি Jenkins Official Site থেকে এটি ডাউনলোড করতে পারেন।
  2. Node.js এবং JasmineJS ইনস্টল করা: Jenkins এ আপনার প্রজেক্টে Node.js এবং JasmineJS ইন্সটল করতে হবে।
    • Jenkins সেল (Jenkins Console) থেকে নিচের কমান্ডগুলো চালান:

      npm install jasmine --save-dev
      
  3. Jenkins Job তৈরি করা:
    • Jenkins এর ড্যাশবোর্ডে গিয়ে একটি নতুন Freestyle Project তৈরি করুন।
    • Source Code Management ট্যাবে আপনার গিট রিপোজিটরি যোগ করুন।
    • Build ট্যাবে, Execute Shell বা Execute Windows Batch Command অপশন সিলেক্ট করে নিচের কমান্ডটি দিন:

      npm install
      npm test
      
    • এখানে npm test JasmineJS টেস্ট রান করবে। আপনি যদি Jasmine টেস্ট ফ্রেমওয়ার্কের জন্য কাস্টম স্ক্রিপ্ট সেট করে থাকেন, তবে সেখানে তার নাম ব্যবহার করবেন।
  4. Job রান করা:
    • এখন, Jenkins এর মাধ্যমে আপনার কোড কমিট করার পর অটোমেটিকভাবে JasmineJS টেস্ট রান হবে এবং টেস্ট ফলাফল দেখাবে।

GitHub Actions এর সাথে JasmineJS Integration

GitHub Actions হল একটি CI/CD টুল যা GitHub রিপোজিটরিতে বিল্ড, টেস্ট এবং ডিপ্লয়মেন্ট প্রক্রিয়া অটোমেট করতে সাহায্য করে।

Steps to Integrate JasmineJS with GitHub Actions:

  1. GitHub Actions Workflow তৈরি করা:
    • আপনার রিপোজিটরির .github/workflows/ ফোল্ডারে একটি নতুন YAML ফাইল তৈরি করুন (যেমন test.yml বা ci.yml)।
  2. YAML কনফিগারেশন: নিচে একটি সাধারণ GitHub Actions Workflow এর উদাহরণ দেয়া হল:

    name: JasmineJS Tests
    
    on:
      push:
        branches:
          - main
      pull_request:
        branches:
          - main
    
    jobs:
      test:
        runs-on: ubuntu-latest
        
        steps:
          - name: Checkout code
            uses: actions/checkout@v2
          
          - name: Set up Node.js
            uses: actions/setup-node@v2
            with:
              node-version: '14'
          
          - name: Install dependencies
            run: npm install
          
          - name: Run JasmineJS tests
            run: npm test
    
  3. Workflows Run:
    • যখন আপনি push বা pull request করবেন, GitHub Actions স্বয়ংক্রিয়ভাবে JasmineJS টেস্ট চালাবে এবং টেস্টের ফলাফল শো করবে।

Travis CI এর সাথে JasmineJS Integration

Travis CI আরেকটি জনপ্রিয় CI/CD টুল যা গিটহাব রিপোজিটরির সাথে ইন্টিগ্রেট করা যায়।

Steps to Integrate JasmineJS with Travis CI:

  1. Travis CI একাউন্ট তৈরি করা: Travis CI এ একটি একাউন্ট তৈরি করুন এবং আপনার গিটহাব রিপোজিটরি সংযুক্ত করুন।
  2. Travis CI কনফিগারেশন ফাইল তৈরি করা:

    • রিপোজিটরির রুট ফোল্ডারে .travis.yml নামে একটি কনফিগারেশন ফাইল তৈরি করুন। উদাহরণস্বরূপ:
    language: node_js
    node_js:
      - "14"
    
    install:
      - npm install
    
    script:
      - npm test
    
  3. Travis CI টেস্ট রান:
    • কোড পুশ করার পর Travis CI স্বয়ংক্রিয়ভাবে JasmineJS টেস্ট চালাবে।

CircleCI এর সাথে JasmineJS Integration

CircleCI একটি আরেকটি জনপ্রিয় CI/CD টুল যা খুব দ্রুত এবং সহজে টেস্ট, বিল্ড এবং ডিপ্লয়মেন্ট প্রক্রিয়া পরিচালনা করতে সক্ষম।

Steps to Integrate JasmineJS with CircleCI:

  1. CircleCI একাউন্ট তৈরি করা: CircleCI এ একটি একাউন্ট তৈরি করুন এবং আপনার রিপোজিটরি সংযুক্ত করুন।
  2. CircleCI কনফিগারেশন ফাইল তৈরি করা:

    • রিপোজিটরির .circleci/config.yml ফোল্ডারে একটি কনফিগারেশন ফাইল তৈরি করুন:
    version: 2.1
    
    jobs:
      test:
        docker:
          - image: cimg/node:14.17
        steps:
          - checkout
          - run:
              name: Install dependencies
              command: npm install
          - run:
              name: Run Jasmine tests
              command: npm test
    
    workflows:
      version: 2
      test:
        jobs:
          - test
    
  3. CircleCI টেস্ট রান:
    • যখন আপনি কোড কমিট করবেন, CircleCI স্বয়ংক্রিয়ভাবে JasmineJS টেস্ট রান করবে।

সারাংশ

  • CI/CD Pipeline এর সাথে JasmineJS ইন্টিগ্রেট করা অটোমেটিক টেস্টিং নিশ্চিত করে এবং ডেভেলপমেন্ট প্রক্রিয়াকে দ্রুত এবং সুনির্দিষ্ট করে তোলে।
  • Jenkins, GitHub Actions, Travis CI, এবং CircleCI এর মতো জনপ্রিয় CI/CD টুলগুলো JasmineJS এর সাথে ইন্টিগ্রেট করা সম্ভব, যা টেস্টিং এবং ডিপ্লয়মেন্ট প্রক্রিয়াকে স্বয়ংক্রিয় করে।
  • JasmineJS এর মাধ্যমে টেস্টের ফলাফল দ্রুত পাওয়া যায়, যা কোডে কোনো ত্রুটি থাকলে সেগুলো দ্রুত চিহ্নিত করতে সাহায্য করে এবং কোডের গুণগত মান নিশ্চিত করে।
Content added By

JasmineJS এর সাথে CI টুলস (Jenkins, Travis CI) ইন্টিগ্রেশন

239

Continuous Integration (CI) টুলস, যেমন Jenkins এবং Travis CI, ডেভেলপমেন্ট প্রক্রিয়ায় স্বয়ংক্রিয়ভাবে কোডের বিল্ড, টেস্টিং এবং ডিপ্লয়মেন্ট পরিচালনা করতে ব্যবহৃত হয়। JasmineJS একটি JavaScript টেস্টিং ফ্রেমওয়ার্ক, যা এই CI টুলগুলোর সাথে ইন্টিগ্রেট করে স্বয়ংক্রিয় টেস্টিংয়ের মাধ্যমে কোডের গুণগত মান নিশ্চিত করতে সহায়তা করে। এর মাধ্যমে, প্রতিটি কোড পরিবর্তনের পর টেস্ট চালানো যায়, যা কোডের মান বজায় রাখতে সহায়তা করে এবং দ্রুত ডেভেলপমেন্ট সাইকেল নিশ্চিত করে।

এই আর্টিকেলে, আমরা JasmineJS এর সাথে দুটি জনপ্রিয় CI টুলস Jenkins এবং Travis CI এর ইন্টিগ্রেশন পদ্ধতি আলোচনা করব।


Jenkins এর সাথে JasmineJS ইন্টিগ্রেশন

Jenkins একটি ওপেন সোর্স অটোমেটেড বিল্ড এবং কন্টিনিউয়াস ইনটিগ্রেশন সিস্টেম। এটি কোড বিল্ড, টেস্ট এবং ডিপ্লয়মেন্ট প্রক্রিয়াকে স্বয়ংক্রিয়ভাবে পরিচালনা করতে সক্ষম। JasmineJS এর সাথে Jenkins ইন্টিগ্রেট করতে, নিচের পদক্ষেপগুলো অনুসরণ করা হয়:

Jenkins সেটআপ এবং JasmineJS টেস্ট রান করা

  1. Jenkins ইনস্টল করুন: প্রথমে Jenkins ইনস্টল করতে হবে। আপনি Jenkins অফিসিয়াল সাইট থেকে Jenkins এর সর্বশেষ সংস্করণ ডাউনলোড করে ইনস্টল করতে পারেন।
  2. Jenkins প্রজেক্ট তৈরি করুন: Jenkins ড্যাশবোর্ডে গিয়ে একটি নতুন প্রজেক্ট (Job) তৈরি করুন:
    • "New Item" নির্বাচন করুন।
    • "Freestyle Project" নির্বাচন করুন এবং প্রজেক্টের নাম দিন।
  3. Source Code Repository কনফিগার করুন: আপনার JasmineJS টেস্টের কোড যেখানে রাখা আছে (যেমন, GitHub বা Bitbucket) সেটি Jenkins-এ কনফিগার করুন:
    • Source Code Management সেকশনে গিয়ে আপনার Git রিপোজিটরি URL প্রদান করুন।
    • Jenkins প্রতি বিল্ডের জন্য Git রিপোজিটরি থেকে কোড ক্লোন করবে।
  4. JasmineJS টেস্ট রান করার জন্য Build Step যোগ করুন: টেস্ট রান করার জন্য Jenkins-এ Build সেকশনে Execute Shell বা Execute Windows batch command নির্বাচন করুন এবং Jasmine টেস্ট রান করার জন্য নিচের কমান্ড দিন:

    npm install   # যদি JasmineJS এবং অন্যান্য ডিপেন্ডেন্সি ইনস্টল না করা থাকে
    npm test      # অথবা, আপনার Jasmine টেস্ট ফাইল রান করার জন্য উপযুক্ত স্ক্রিপ্ট
    
  5. বিল্ড ট্রিগার: আপনি চাইলে Jenkins-এ Build Triggers সেট করতে পারেন, যেমন GitHub এর পরিবর্তনের পর (Webhook ব্যবহার করে) বা নির্দিষ্ট সময় অন্তর (সিডিউল করা) বিল্ড ট্রিগার করা।
  6. ফলাফল দেখতে: Jenkins আপনার টেস্টের ফলাফল কনসোলে প্রদর্শন করবে এবং যদি কোনো টেস্ট ফেল হয়, তবে আপনি বিস্তারিত ত্রুটি বার্তা দেখতে পারবেন।

উদাহরণ: Jenkins কনফিগারেশন (Shell Script)

#!/bin/bash
echo "Running Jasmine Tests"
npm install
npm test

Travis CI এর সাথে JasmineJS ইন্টিগ্রেশন

Travis CI একটি ক্লাউড ভিত্তিক কন্টিনিউয়াস ইনটিগ্রেশন সিস্টেম যা GitHub প্রজেক্টের সাথে ইন্টিগ্রেট করে কোড বিল্ড এবং টেস্টিং পরিচালনা করতে সক্ষম। JasmineJS টেস্ট রান করতে Travis CI-এর সাথে ইন্টিগ্রেশন সহজ এবং কার্যকর।

Travis CI সেটআপ এবং JasmineJS টেস্ট রান করা

  1. GitHub রিপোজিটরি কানেক্ট করা: প্রথমে, আপনি আপনার GitHub রিপোজিটরি Travis CI-তে কানেক্ট করতে হবে। আপনি Travis CI এর ওয়েবসাইটে গিয়ে GitHub রিপোজিটরি যুক্ত করতে পারেন।
  2. .travis.yml ফাইল তৈরি করা: আপনার প্রকল্পের রুট ডিরেক্টরিতে .travis.yml ফাইল তৈরি করুন। এই ফাইলটি Travis CI-কে নির্দেশ দেয় কীভাবে টেস্টগুলো চালাতে হবে এবং কোন পরিবেশে টেস্ট রান করতে হবে।

    উদাহরণ:

    language: node_js
    node_js:
      - "14"  # অথবা আপনার প্রজেক্টের জন্য উপযুক্ত Node.js ভার্সন
    
    install:
      - npm install  # ডিপেন্ডেন্সি ইনস্টল
    
    script:
      - npm test    # Jasmine টেস্ট চালানো
    
  3. Travis CI বিল্ড রান করা: Travis CI আপনার GitHub রিপোজিটরিতে নতুন কোড পুশ হওয়ার পর বা নির্দিষ্ট সময় অন্তর স্বয়ংক্রিয়ভাবে টেস্ট রান করবে। প্রতিটি বিল্ডের পরে, আপনি Travis CI ড্যাশবোর্ডে টেস্টের ফলাফল দেখতে পাবেন।
  4. ফলাফল দেখা: Travis CI বিল্ডের ফলাফল এবং JasmineJS টেস্টের আউটপুট কনসোল লগে দেখাবে, যেখানে আপনি টেস্টের স্টেটাস (পাস/ফেল) এবং ত্রুটি বার্তা পাবেন।

Jenkins এবং Travis CI এর তুলনা

ফিচারJenkinsTravis CI
ইনস্টলেশনলোকাল সার্ভারে ইনস্টল করতে হয়ক্লাউড ভিত্তিক, শুধুমাত্র GitHub প্রজেক্টের জন্য
কনফিগারেশনGUI এবং Script-based কনফিগারেশন.travis.yml ফাইলের মাধ্যমে কনফিগারেশন
পারফরম্যান্সউচ্চ পারফরম্যান্স, বড় প্রকল্পে উপযুক্তছোট এবং মাঝারি প্রকল্পের জন্য উপযুক্ত
ইন্টিগ্রেশনঅনেক বিভিন্ন টুলের সাথে ইন্টিগ্রেট করা যায়GitHub, Bitbucket এর সাথে সহজ ইন্টিগ্রেশন
কাস্টমাইজেশনঅনেক বেশি কাস্টমাইজেশন অপশন আছেসীমিত কাস্টমাইজেশন, তবে সহজ কনফিগারেশন

সারাংশ

  • Jenkins এবং Travis CI দুটি CI টুল JasmineJS টেস্টিং ফ্রেমওয়ার্কের সাথে ইন্টিগ্রেট করা যায়, যার মাধ্যমে কোড পরিবর্তন হলে স্বয়ংক্রিয়ভাবে টেস্ট রানের সুবিধা পাওয়া যায়।
  • Jenkins-এ টেস্ট রান করার জন্য আপনি একটি freestyle project তৈরি করে npm test চালাতে পারেন, যেখানে Travis CI .travis.yml ফাইল ব্যবহার করে সরাসরি টেস্ট চালানোর জন্য কনফিগার করা হয়।
  • CI টুলগুলোর মাধ্যমে টেস্টিং প্রক্রিয়া অটোমেট করা হয়, যার ফলে কোডের গুণগত মান বজায় থাকে এবং দ্রুত ডেভেলপমেন্ট সাইকেল নিশ্চিত হয়।
Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...